<template>
  <ul class="todo-main">
    <Item v-for="todo in todos" :key="todo.id" :todo="todo" :deleteTodo="deleteTodo" :toggleTodo="toggleTodo"/>
  </ul>
</template>

<script setup lang="ts">
import Item from "./Item.vue";
import type {Todo, Todos} from '../types'  // 引入类型
// 声明接收属性
// defineProps(['todos'])
/* defineProps({
  todos: {
    type: Array,
    required: true
  }
}) */

defineProps<{
  todos: Todos,
  deleteTodo: (id: number) => void
  toggleTodo: (todo: Todo) => void
}>()


</script>


<style scoped>
.todo-main {
  margin-left: 0px;
  border: 1px solid #ddd;
  border-radius: 2px;
  padding: 0px;
}

.todo-empty {
  height: 40px;
  line-height: 40px;
  border: 1px solid #ddd;
  border-radius: 2px;
  padding-left: 5px;
  margin-top: 10px;
}
</style>
